<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "https://www.w3.org/TR/html4/loose.dtd">
<html lang="zh-CN"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><meta http-equiv="Content-Language" content="zh-CN"><link href="stylesheet.css" media="all" rel="stylesheet" type="text/css">
<title>作为复杂优化问题的查询处理</title>
<script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?d286c55b63a3c54a1e43d10d4c203e75"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script>
</head><body class="SECT1">
<div>
<table summary="Header navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><th colspan="5" align="center" valign="bottom">PostgreSQL 8.2.3 中文文档</th></tr>
<tr><td width="10%" align="left" valign="top"><a href="geqo.html" accesskey="P">后退</a></td><td width="10%" align="left" valign="top"><a href="geqo.html">快退</a></td><td width="60%" align="center" valign="bottom">章48. 基因查询优化器</td><td width="10%" align="right" valign="top"><a href="geqo.html">快进</a></td><td width="10%" align="right" valign="top"><a href="geqo-intro2.html" accesskey="N">前进</a></td></tr>
</table>
<hr align="LEFT" width="100%"></div>
<div class="SECT1"><h1 class="SECT1"><a name="GEQO-INTRO">48.1. 作为复杂优化问题的查询处理</a></h1>
<p>在所有关系型操作符里，最难以处理和优化的一个是<i class="FIRSTTERM">连接</i>。一个查询需要回答的可选规划的数目将随着该查询包含的连接的个数呈指数增长。在访问关系分支时的进一步优化措施是由多种多样的<i class="FIRSTTERM">连接方法</i>(例如嵌套循环、索引扫描、融合连接等)来支持处理独立的连接和多种多样的<i class="FIRSTTERM">索引</i>(比如 B-tree, hash, GiST, GIN)。</p>
<p>目前 PostgreSQL 优化器的实现在候选策略空间里执行一个<i class="FIRSTTERM">近似穷举搜索</i>。这个算法最早是在 IBM System R database 数据库中引入的，它生成一个近乎最优的连接顺序，但是如果查询中的连接增长得很大，它可能会消耗大量的时间和内存空间。这样就使普通的 PostgreSQL 查询优化器不适合那种连接了大量表的查询。</p>
<p>德国弗来堡矿业及技术大学自动控制系的成员在试图把 PostgreSQL 作为用于一个电力网维护中做决策支持的知识库系统的后端时，碰到了上面的问题。该 DBMS 需要为知识库系统的推导机处理很大的连接查询。在可能的查询规划空间里进行检索的恶劣性能引起了人们对发展新的优化技术的需求。</p>
<p>在随后的内容里，描述了一个<i class="FIRSTTERM">基因算法</i>，这个算法用一种对涉及大量连接的查询很有效的方式解决了连接顺序的问题。</p>
</div>
<div>
<hr align="LEFT" width="100%">
<table summary="Footer navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><td width="33%" align="left" valign="top"><a href="geqo.html" accesskey="P">后退</a></td><td width="34%" align="center" valign="top"><a href="index.html" accesskey="H">首页</a></td><td width="33%" align="right" valign="top"><a href="geqo-intro2.html" accesskey="N">前进</a></td></tr>
<tr><td width="33%" align="left" valign="top">基因查询优化器</td><td width="34%" align="center" valign="top"><a href="geqo.html" accesskey="U">上一级</a></td><td width="33%" align="right" valign="top">基因算法</td></tr>
</table>
</div>
</body></html>